package com.togo.exam;

/**
 * @Author K2
 * @Description 输入是一个有序数组，如（1,3,8,9,2983,19203,20312,94888），
 * 给定一个数字K，请找到一个位置，当K插入数组后，数组仍然是有序的。
 * @Date 上午10:37 2023/2/17
 **/
public class Test {

    public int solution(int[] arr, int k) {
        if (arr == null || arr.length == 0) return -1;
        int left = 0, right = arr.length;

        while (left < right) {
            int index = (left + right) / 2;
            if (arr[index] > k) {
                right = index;
            } else {
                left = index + 1;
            }
        }

        return left;
    }

    public static void main(String[] args) {
        Test test = new Test();
        int[] arr = new int[]{1, 3, 8, 9, 2983, 19203, 20312, 94888};
        System.out.println(test.solution(arr, 300000));
    }
}
